<template>
	<div class="message">
		<span v-if="isError">
			<span class="repl-icon icon-error" />
			<strong>{{ ' ' + message.name }}:</strong>
		</span>
		{{ message.message }}
		<a
			v-if="isGuideUrl(message.url)"
			:href="message.url!.slice(websitePrefix.length)"
			class="link"
			:class="{ error: isError }"
			>(<span class="link-text">link</span>)</a
		>
	</div>
	<pre v-if="frame" class="frame"><code>{{ frame }}</code></pre>
</template>

<script setup lang="ts">
import { computed } from 'vue';
import type { RollupError } from '../../../src/rollup/types';
import { getFileNameFromMessage } from '../helpers/messages';

const properties = defineProps<{ isError?: boolean; message: RollupError }>();

const websitePrefix = 'https://rollupjs.org';

const frame = computed(() => {
	const { loc, id, frame } = properties.message;
	const fileName = getFileNameFromMessage({ id, loc });
	if (fileName && (loc || frame)) {
		const location = loc ? ` (${loc.line}:${loc.column})` : '';
		return `${fileName}${location}${frame ? `\n${frame}` : ''}`;
	}
	return '';
});

const isGuideUrl = (url: string | undefined) => url && url.startsWith(websitePrefix);
</script>

<style scoped>
.message {
	line-height: 1.2;
}

.frame {
	overflow: hidden;
	word-break: normal;
	margin: 5px 0;
}

.link {
	margin: 0 2px;
}

.link-text {
	border-bottom: 1px solid #dd9999;
}

.link.error {
	color: #eeeeee;
}

.link.error .link-text {
	border-bottom: 1px solid #ffaaaa;
}
</style>
